const path = require('path')
function resolve(dir) {
  return path.join(__dirname, './', dir)
}

module.exports = {
  transpileDependencies: [
    'vuetify',
    'vue-tel-input-vuetify'
  ],
  devServer: {
    proxy: {
      '/dev-api': {
        target: 'http://124.223.67.137',
        pathRewrite: { '^/dev-api': '' }
      }
    }
  },
  chainWebpack: config => {
    // svg 规则
    const svgRule = config.module.rule('svg') // 找到原有的svg-loader
    svgRule.uses.clear() // 清除已有的loader, 如果不清除会在原有loader之后再使用当前loader规则
    svgRule.exclude.add(/node_modules/) // 正则匹配排除node_modules目录
    svgRule // 添加svg新的loader处理
      .test(/\.svg$/)
      .use('svg-sprite-loader')
      .loader('svg-sprite-loader')
      .options({
        symbolId: 'icon-[name]'
      })

    // 修改images loader，添加svg处理
    const imagesRule = config.module.rule('images')
    imagesRule.exclude.add(resolve('src/assets/svg'))
    config.module
      .rule('images')
      .test(/\.(png|jpe?g|gif|svg)(\?.*)?$/)
  },
  publicPath: process.env.NODE_ENV === 'dev' ? '/' : './'
}
